home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Cream of the Crop 1
/
Cream of the Crop 1.iso
/
PROGRAM
/
CBGRX100.ARJ
/
DRAWPOLY.C
< prev
next >
Wrap
Text File
|
1992-04-10
|
2KB
|
64 lines
/**
** DRAWPOLY.C
**
** Copyright (C) 1992, Csaba Biegl
** 820 Stirrup Dr, Nashville, TN, 37221
** csaba@vuse.vanderbilt.edu
**
** This file is distributed under the terms listed in the document
** "copying.cb", available from the author at the address above.
** A copy of "copying.cb" should accompany this file; if not, a copy
** should be available from where this file was obtained. This file
** may not be distributed without a verbatim copy of "copying.cb".
** You should also have received a copy of the GNU General Public
** License along with this program (it is in the file "copying");
** if not, write to the Free Software Foundation, Inc., 675 Mass Ave,
** Cambridge, MA 02139, USA.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**/
#include "grx.h"
#include "libgrx.h"
static void drawpoly(int n,int pt[][2],int c,int last)
{
int ii,op;
if((n <= 2) ||
(last && (pt[0][0] == pt[n-1][0]) &&
(pt[0][1] == pt[n-1][1]) &&
(--n == 2))) {
if(n <= 0) return;
if(n == 1) { GrPlot(pt[0][0],pt[0][1],c); return; }
GrLine(pt[0][0],pt[0][1],pt[1][0],pt[1][1],c);
return;
}
op = C_OPER(c);
for(ii = 0; ii < (n - 1); ii++) {
GrLine(pt[ii][0],pt[ii][1],pt[ii+1][0],pt[ii+1][1],c);
if((ii > 0) && (op == C_XOR)) GrPlot(pt[ii][0],pt[ii][1],c);
}
if(last) {
GrLine(pt[ii][0],pt[ii][1],pt[0][0],pt[0][1],c);
if(op == C_SET) {
GrPlot(pt[ii][0],pt[ii][1],c);
GrPlot(pt[0][0],pt[0][1],c);
}
}
}
void GrPolyLine(int numpts,int points[][2],int c)
{
drawpoly(numpts,points,c,FALSE);
}
void GrPolygon(int numpts,int points[][2],int c)
{
drawpoly(numpts,points,c,TRUE);
}